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(54) Smart programming of flash memory 

(57) A reprogrammable network communication de- 
vice which communicates on a network has a repro- 
grammable read only memory which stores a current 
program image, a current network information file block 
containing configuration information for the network 
communication device, and a software module for re- 
programming the reprogrammable read only memory. A 
random access memory stores a new program image 
for the reprogrammable read only memory. A processor 
sends and receives network communications, confirms 
that the new program image is compatible with the con- 
figuration information in the current network information 
file block, and executes the software reprogramming 
module so as to re prog ram the reprogrammable read 
only memory with the new program image in a case 
where compatibility is confirmed. 
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Description 

The present invention concerns a reprogrammable 
network communication device which communicates on 
a network. More particularly, the present invention re- 
lates to a reprogrammable network communication de- 
vice which confirms that it is being reprogrammed with 
a compatible image before it allows reprogramming to 
occur. 

EP-A-0598513 (Representative's reference 
2274430) corresponding to U.S. Patent Application Se- 
rial No. 07/978,369 ; entitled "Method And Apparatus For 
Interfacing A Peripheral To A Local Area Network", is 
hereby incorporated by reference. 

In recent years, as local area networks (LANs) grow 
more complex, it has become common to upgrade net- 
work communication devices with the newest technolo- 
gy available. Such upgrades are easiest to perform over 
the LAN. For example, a network administrator can re- 
motely alter a firmware image on a network communi- 
cation device by downloading new data to the device, 
which then reprograms itself with the new firmware im- 
age. 

A typical personal computer (PC) onto which a net- 
work administrator may log, however, may be connect- 
ed to more than one LAN. For example, a PC may be 
connected to both an Ethernet LAN and to a Token-ring 
LAN, and may function as the network administrator for 
both networks Each of the LANs may in turn be con- 
nected to several reprogrammable network communi- 
cation devices. Thus, in such a structure, there are mul- 
tiple devices which the network administrator can po- 
tentially re prog ram, and there is therefore a possibility 
that the network administrator might inadvertently repro- 
gram one of those devices with an incompatible image. 

The results of downloading an incompatible image 
can be devastating. For example, if the network admin- 
istrator erroneously downloads a Token-ring image to a 
card connected to an Ethernet LAN, and that card then 
reprograms itself with the Token-ring image, it will no 
longer be able to communicate on an Ethernet LAN at 
all. This means that the card could not even be repro- 
grammed over the LAN - it is, quite literally, a "dead" 
board as far as the Ethernet LAN is concerned. Other 
incompatibilities, suchas : for example, incompatibilities 
in the host interface configuration, product configura- 
tion, processor configuration and memory configuration, 
can result in "dead" boards. 

To prevent such disastrous results in the case 
where a network communication device is downloaded 
with an incompatible image : the present invention en- 
sures that the downloaded image is compatible before 
the actual reprogramming occurs. 

In one aspect of the present invention, a reprogram- 
mable network communication device which communi- 
cates on a network includes a reprogrammable read 
only memory which stores a current program image, a 
current network information file block containing config- 



uration information for the network communication de- 
vice, and a software module for reprogramming the re- 
programmable read only memory. A random access 
memory stores a new program image for the reprogram- 

s mable read only memory. A processor, which sends and 
receives network communications, confirms that the 
new program image is compatible with the configuration 
information in the current network information file block, 
and executes the software reprogramming module so 

10 as to reprogram the reprogrammable read only memory 
with the new program image in a case where compati- 
bility is confirmed. 

In preferred embodiments of the present invention, 
the new program image includes a new network infor- 

75 mation file block, and the processor replaces board-in- 
variant portions of the new network information file block 
with corresponding portions of the current network in- 
formation file block before execution of the software 
module. In particularly preferred embodiments of the 

20 present invention, the configuration information in the 
current network information file block includes a MAC 
address, network media configuration information, host 
interface configuration information, product configura- 
tion information, processor configuration information 

25 and memory configuration information. The processor 
confirms compatibility of the new program image by 
comparing the configuration information in the current 
network information file block with configuration infor- 
mation in the new network information file block. 

30 This brief summary has been provide so that the 
nature of the invention may be understood quickly A 
more complete understanding of the invention can be 
obtained by reference to the following detailed descrip- 
tion of the preferred embodiment thereof in connection 

35 with the attached drawings. 



BRIEF DESCRIPTION OF THE DRAWINGS 

Figure 1 is a diagram of a local area network and 
wide area network to which a network board is coupled. 

Figure 2 is a cut-away perspective view of the net- 
work board fitted into a Canon LBP 1 260 laser printer. 

Figure 3 is a block diagram showing the network 
board coupled between a printer and a local area net- 
work. 

Figure 4 is a diagram showing the physical layout 
of components on the network board. 

Figure 5 is a drawing of a face plate for the network 
board. 

Figure 6 is a functional block diagram of the network 
board. 

Figure 7 is a diagram showing examples of several 
software modules that may be stored in the flash 
EPROM. 

Figure 8 is a block diagram of an arrangement used 
to determine which connector is connected to the net- 
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work. 

Figure 9 is a flowchart showing how to detect which 
connector is connected to the network. 

Figure 1 0 is a flow chart showing the operation of a 
PRETASK software module. 

Figures 11(a) through 11(d) are diagrams showing 
possible relationships of various network soltware mod- 
ules. 

Figure 1 2 is a block diagram showing a PC connect- 
ed to a Ethernet local area network and a Token-ring 
local area network. 

Figure 13 is a diagram showing contents of a net- 
work information file block used for storing configuration 
information. 

Figure 14 is a flowchart showing reprogramming of 
flash EPROM. 

Figure 1 5 is a block diagram of a memory arbitration 
device. 

Figure 16 is a block diagram of one preferred con- 
struction of a shared memory arbiter in the arbitration 
device. 

Figure 17 is a diagram showing the timing of signals 
provided to the arbitration device. 

Figure 1 8 is a diagram showing the configuration of 
shared memory. 

Figure 19 is a flowchart showing the operations in- 
volved in writing into shared memory. 

Figure 20 is a flowchart showing operations in- 
volved in reading from shared memory. 

Figures 21(a) through 21(c) show various alterna- 
tives for configuring shared memory. 

Figure 22 is a block diagram of a serial port. 

Figures 23(a) and 24(a) are flowcharts showing op- 
erations involved in receiving and sending serial com- 
munications over the serial port. 

Figures 23(b) and 24(b) are diagrams showing the 
timing of signals in the serial receive and send modes. 

DETAILED DESCRIPTION OF THE PREFERRED 
EMBODIMENT 

In its most preferred form, the present invention is 
embodied in a network board (or "NEB") which provides 
hardware, software and firmware solutions for making 
a network peripheral, such as a printer, an intelligent, 
interactive network member, capable not only of receiv- 
ing and processing data from the network, but also of 
transmitting to the network significant amounts of data 
about the peripheral such as detailed status information, 
operational parameters and the like. It is also possible 
to use the invention in other networked peripherals such 
as scanning, facsimile, copier, image processing and 
other such peripherals. Integration of such hardware, 
software and firmware with the peripheral eliminates the 
need to dedicate a personal computer to act as a pe- 
ripheral server. 



[Network Architecture] 

Figure 1 is a diagram showing the present invention 
incorporated into a NEtwork Board (NEB) 101 coupled 

s to a printer 102 having an open architecture. NEB 101 
is coupled to local area network (LAN) 100 through a 
LAN interface, for example, an Ethernet interface 
10Base-2 with a Coax connector or 10Base-T with an 
RJ-45 connector. 

10 Plural personal computers (PCs), such as PCs 103 
and 104, are also connected to LAN 100, and under con- 
trol of the network operating system these PCs are able 
to communicate with NEB 1 01 . One of the PCs, such as 
PC 103, may be designated for use as the network ad- 

15 ministrator. A PC may have a printer connected to it, 
such as printer 1 05 connected to PC 104. 

Also connected to LAN 100 is file server 106 which 
manages access to files stored on a large capacity (e. 
g., 1 0 gigabyte) network disk 1 07. A print server 1 08 pro- 

20 vides print services to printers 109 and 110 connected 
to it, as well as to remote printers such as printer 1 05. 
Other unshown peripherals may also be connected to 
LAN 100. 

In more detail, the network depicted in Figure 1 may 

25 utilize any network software such as Novell or UNI X soft- 
ware in order to effect communication among the vari- 
ous network members. The present embodiments will 
be described with respect to a LAN utilizing Novell Net- 
Ware® software, although any network software could 

30 be used. A detailed description of this software package 
may be found in 'NetWare® User's Guide" and "Net- 
Ware® Supervisor's Guide", published by M&T Books, 
copyrighted 1990, incorporated herein by reference. 
See also the "NetWare® Printer Server" by Novell, 

35 March 1991 edition, Novell Part No. 100-000892-001. 

Briefly, file server 1 06 acts as a file manager, receiv- 
ing, storing, queuing, caching, and transmitting files of 
data between LAN members. For example, data files 
created respectively at PCs 1 03 and 1 04 may be routed 

40 to file server 106 which may order those data files and 
then transfer the ordered data files to printer 109 upon 
command from print server 10B. 

PCs 103 and 104 may each comprise a standard 
PC capable of generating data files, transmitting them 

45 onto LAN 100, receiving files from LAN 100, and dis- 
playing and/or processing such files. However, while 
personal computer equipment is illustrated in Figure 1 , 
other computer equipment may also be included, as ap- 
propriate to the network software being executed. For 

50 example, UNIX workstations may be included in the net- 
work when UNIX software is used, and those worksta- 
tions may be used in conjunction with the illustrated 
PC's under appropriate circumstances. 

Typically, a LAN such as LAN 100 services a fairly 

ss localized group of users such as a group of users on 
one floor or contiguous floors in a building. As users be- 
come more remote from one another, for example, in 
different buildings or different states, a wide area net- 
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work (WAN) may be created which is essentially a col- 
lection of several LANs all connected by high speed dig- 
ital lines, such as high speed integrated services digital 
network (ISDN) telephone lines. Thus, as shown in Fig- 
ure 1 , LANs 1 00, 110 and 1 20 are connected to form a 
WAN via modulator/demodulator (MODEM)/transpond- 
er 130 and backbone 140, which is simply an electrical 
connection between several buses. Each LAN includes 
its own PCs, and each ordinarily includes its own file 
server and print server, although that is not necessarily 
the case. 

Thus, as shown in Figure 1, LAN 110 includes PCs 
1 1 1 and 1 1 2, file server 113, network disk 114, print serv- 
er 115 and printers 116 and 117. LAN 120, on the other 
hand, includes only PCs 121 and 1 22. Via WAN connec- 
tions, equipment in any of LANs 100, 110 and 120 can 
access the capabilities of equipment in any other of the 
LANs. 

PC 1 04 may be embedded with an RPRINTER soft- 
ware program, and as such may exert limited control 
over network peripherals. The RPRINTER program is 
an MS-DOS terminate-and-stay-resident ("TSR") pro- 
gram which allows users to share printer 1 05 connected 
to PC 104 while at the same time allowing PC 104 to 
execute other non-print applications. RPRINTER is a 
relatively unintelligent program that does not have the 
ability to search printer queues for work. RPRINTER 
gets its work from print server 1 08 running elsewhere in 
the network. Because it communicates with the at- 
tached printer over the printer's parallel port, PC 104 
running RPRINTER is able to obtain only limited status 
information from printer 105 and to return that status in- 
formation to print server 1 08 over LAN 1 00. From a con- 
trol standpoint, RPRINTER allows stopping of a print job 
(when, for example, the printer is out of paper or off-line) 
and little more. Some printers include RPRINTER fea- 
tures by offering internal or external circuit boards that 
provide the same limited features of the RPRINTER 
TSR program running in a personal computer 

Print server 108 is capable of exercising more sig- 
nificant control over LAN peripherals but requires a ded- 
icated PC which cannot be used for any other task. Print 
server 108, which may itself be a PC : has the ability to 
service multiple user-defined print queues, perform dy- 
namic search queue modification, and provide defined 
notification procedures for exception (failure) conditions 
and status and control capabilities, and can control both 
local printers 109 and 110 (that is, printers physically 
connected to print server 108) and remote printers. Lo- 
cal printers 109 and 110 can be connected to either se- 
rial or parallel ports, and the remote printers, such as 
printer 105, are printers running elsewhere in the system 
which print server 108 controls through RPRINTER soft- 
ware. 

Print server 108 can control many local or remote 
printers and can request print information from many file 
server queues. However, there are several drawbacks 
to relying on print server 108 to control network printing 



services. A first drawback is that multiple printer streams 
must all be funnelled through a single network node. 
This can become a bottleneck. A second drawback is 
that for the most efficient operation, the printers should 

5 be connected to the print server locally, like printers 109 
and 110. This can be an inconvenience for users since 
it requires the printers to be clustered around print serv- 
er 108 and also requires users to travel to those clus- 
tered printers. A third drawback is that if the controlled 

10 printers are remote, as in the case of printer 105 which 
is serviced by RPRINTER, then print data must make 
several trips, first from file server 106 to print server 108, 
and then from print server 108 to the printer running 
RPRINTER. This is inefficient. 

is A fourth drawback is the limited amount of printer 
status and control information offered through print serv- 
er 108. It has already been stated that RPRINTER does 
not allow for much more than rudimentary status infor- 
mation such as "out of paper" and "off line". Print server 

20 108 does not offer more than this because it was de- 
signed with consideration of the limitations of the per- 
sonal computer parallel port. 

[The Network Board] 

25 

Installation of NEB 101 into printer 102 provides 
many advantages over the network peripheral control 
entities discussed above, in that it allows printer 102 to 
become an intelligent, interactive network member. 

30 As shown in Figure 2, NEB 1 01 is preferably housed 
in an internal expansion I/O slot of printer 102, which in 
a preferred embodiment of the present invention is a 
Canon LBP 1 260 laser printer. This makes NEB 101 an 
embedded network node having the processing and 

35 data storage features described below. 

The architecture of NEB 1 01 provides an advantage 
in that it has unique support features for administration 
and management of large, multi-area WAN networks. 
These support features could include, for example, 

40 printer control and status monitoring from a remote lo- 
cation on the network (such as from the network admin- 
istrator's office), automatic management of printer con- 
figuration after each print job to provide a guaranteed 
initial environment for a next user, and printer logs or 

45 usage statistics accessible across the network for char- 
acterizing printer workload and scheduling toner car- 
tridge replacement. 

An important parameter in the NEB design is the 
ability to access the printer control state from NEB 101 

so through a bi-directional interface, here a shared memo- 
ry, although other bi-directional interfaces such as SCSI 
interfaces. are also possible. This allows printer console 
information to be exported to NEB 101 or to an external 
network node so as to allow programming of many use- 

55 ful support functions. Blocks of print image data and 
control information are assembled by a microprocessor 
on board NEB 101, they are written into the shared 
memory, and they are then read by printer 102. Like- 
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wise, printer status information is transferred from print- 
er 102 to the shared memory, from where it is read by 
the NEB microprocessor. 

Figure 2 is a cut-away perspective view showing in- 
stallation of NEB 101 into printer 102. As seen in Figure 
2, NEB 101 , which is constructed from a printed circuit 
board 101a on which is mounted face plate 101b which 
allows for network connections, is connected via con- 
nector 1 70 to printer interface card 1 50. As described 
below, printer interface card 150 directly controls the 
print engine in printer 102. Print data and printer status 
commands are fed to printer interface card 150 from 
NEB 101 via connector 170, and printer status informa- 
tion is obtained from card 150 also via connector 170. 
NEB 101 communicates this information onto LAN 100 
via the network connectors on face plate 101b. At the 
same time, printer 102 can also receive print data from 
conventional serial port 102a and parallel port 102b. 

Figure 3 is a block diagram depicting electrical con- 
nection of NEB 101 to printer 102. NEB 101 is directly 
connected to LAN 1 00 via a LAN interface, and to printer 
1 02 via printer interface card 1 50. In a preferred embod- 
iment of the invention, the printer interface card 150 is 
a Peerless LBP-860/1260-External Standard I/O Board 
Interface, available from Peerless Systems Corp., the 
details of which can be found in the Peerless Standard 
I/O Interface Design Specification, revision 2.07a, Peer- 
less Systems Corp., May 10, 1994. The board includes 
an Intel 80960KB-2D microprocessor 151 . Although it is 
a 32-bits machine, microprocessor 151 accesses data 
to and from NEB 101 are in 2 byte wide (16-bit) transfers 
via a shared memory 200 arranged on NEB 101 . Micro- 
processor 1 51 also communicates with print engine 1 60 
which actually drives the printing mechanism. 

[NEB Physical Layout] 

Figure 4 shows the dimensions of a preferred em- 
bodiment of NEB 101 and the physical layout of the ma- 
jor components thereof. The NEB card is 10.0 cm by 
14.2 cm. NEB 101 includes a printer interface card con- 
nector 170 (which in the case of the Peerless printer in- 
terface card is an 80-pin connector) that couples to the 
printer interface card and face plate 300 having connec- 
tors 301 and 302 that allow connection to LAN 100. The 
face plate also includes 4 status light emitting diodes 
(LEDs) 303-306. Arranged on the NEB card are trans- 
ceiver 171, crystal oscillator 172, microprocessor 173, 
arbiter control logic 400, flasl erasable programmable 
read only memory (EPROM) 174, dynamic random ac- 
cess memory (DRAM) 175, first static random access 
memory (SRAM) 200, second SRAM 176, network and 
NEB control logic 500, and serial port connector 600. 
Each of these components will be discussed in greater 
detail below. 

Figure 5 depicts a more detailed view of face plate 
300, the dimensions of which are 11.6 cm by 3.25cm. 
As stated above, NEB 1 01 couples to LAN 100 through 



8 

connectors 301 and 302. Preferably, connector 301 is 
an RJ-45 connector capable of accepting a 10Base-T 
connection, while connector 302 may be a simple coax 
connector capable of accepting a 10Base-2 connection. 

s Status LED 303 is lit when NEB 1 01 is transmitting data 
over LAN 100, and status LED 304 is lit when NEB 101 
is receiving data from LAN 100. Status LED 305 is lit 
when RJ-45 connector 301 is connected to LAN 100, 
while status LED 306 is lit during self-test diagnostics of 

10 NEB 101. Mounting holes 307 accept Screws for fixing 
NEB 101 to printer 102. 

[NEB Architecture] 

15 The architecture of NEB 101 is shown in Figure 6. 
Power for all circuits is supplied to NEB-101 from a +5V 
power source 177. +5V power is also provided to power 
converters 178 and 179. Power converter 178 provides 
-9Vpowertotransceiver 171, while power converter 179 

20 provides +1 2V power to flash EPROM 1 74 for "flashing" 
(i.e., reprogramming of the EPROM). 

Network and NEB control logic 500 is preferably a 
single 144-pin application specific integrated circuit 
(ASIC) that includes a network controller 510 and NEB 

25 control logic 520. Network controller 510 is an NCR 
macro-cell compatible with- National DP83902A "ST- 
NIC Ethernet controller, the details of which can be 
found in National Semiconductor's Local Area Networks 
Databook, National Semiconductor p/n 400055, Nation- 

30 al Semiconductor, 1993. Network controller 510 is de- 
signed to interface with CSMA/CA-type (carrier sense 
multiple access with collision detection) local area net- 
works. 

Network controller 510 connects with RJ-45 con- 
35 nector 301 directly and with coaxial connector 302 
through transceiver 171, which is preferably a National 
Semiconductor DP8392 coaxial transceiver interface, 
the details of which can also be found in National's Local 
Area Networks Databook . Network controller 51 0 is also 
40 coupled to an 8KB SRAM 176 that is used as an in- 
put/output packet buffer for Ethernet data. This memory 
should preferably have an access time of about 70 ns 
or less. 

NEB control logic 520 provides an interface be- 
45 tween network controller 510, microprocessor 173, and 
memory devices EPROM 174 and DRAM 175. NEB 
control logic 520 also interfaces with non-volatile ran- 
dom access memory (NVRAM) 1 80, which is a 256 byte 
serial electrically erasable/programmable memory used 
so for initialization data storage during power cycling of 
printer 102 which houses NEB 101. Network and printer 
configuration parameters are written into NVRAM 180 
when the printer is first installed onto the network to al- 
low NEB software to recover the installation parameters 
55 after printer power has been cycled off and on. 

NEB control logic 520 also couples with serial port 
connector 600, which comprises a receive data pin 601 
and a transmit data pin 602 that can respectively receive 
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and transmit serial data streams for debugging purpos- 
es. NEB control logic 520 senses data present at the 
receive data line and samples the serial bits at regular 
intervals, in a manner that will be discussed in greater 
detail below. 

The central controller of NEB 101 is microprocessor 
173, preferably an Intel 80C188EA-20 8-bit processor, 
the details of which can be found in the 
80C186EA/80188EA User's Manual, Intel p/n 
270950-001 , Intel Corp. This processor is an 8-bit proc- 
essor with direct memory access (DMA), interrupts, tim- 
ers, and a DRAM refresh control. Other microproces- 
sors, such as an AMD 80C1 88-20 8-bit microprocessor, 
might alternatively be used. 256 KB flash EPROM 174 
and 512 KB DRAM 175 are coupled to microprocessor 

173 via NEB control logic 520, while 32 KB SRAM 200 
(which is shared with printer interface card 150) is cou- 
pled with microprocessor 173 via arbiter control logic 
400. A 40 MHz, 50 ppm crystal oscillator 172 provides 
the microprocessor with a clock signal that is wholly sep- 
arate from and asynchronous with the clock signal pro- 
vided to microprocessor 151 on printer interface card 
150. 

Microprocessor 173 executes instructions in flash 
EPROM 174, which stores control firmware and printing 
application software. After power-on self -test (POST), 
code is selectively moved to the higher performance 512 
KB DRAM 175, which should preferably have an access 
time of about 80 ns, for actual execution. Flash EPROM 

174 can be reprogrammed, or "flashed", from LAN 100, 
as discussed below. 

Figure 7 illustrates several examples of blocks of 
code, or modules, that are stored in flash EPROM 174. 
The XPL module provides a standardized interface be- 
tween printer 102 and NEB 101. MLID (Multi Link Inter- 
face Driver) is a piece of Novell code (Media Support 
Module, or MSM) linked together with a piece of cus- 
tomized code (Hardware Support Module, or HSM) that 
is the lowest level of network connection, while LSL 
(Link Support Layer) is a piece of Novell code that acts 
as a multiplexer between the tow level MLID and the 
several protocol stacks above it. CNETX is customized 
code that turns local DOS-like function calls into network 
function calls, providing file functions like OPEN, READ, 
WRITE and CLOSE. 

The PRETASK module is responsible for identifying 
what frame types are associated with the various pos- 
sible protocol stacks, as described below Because NEB 
101 supports multiple protocol stacks, this module ex- 
ists as long as NEB 101 is running. 

Novell's IPX/SPX protocol stack is contained in 
flash EPROM 174, and is supported by SAP, or Service 
Advertising Protocol. SAP is a Novell concept that al- 
lows devices to register themselves into the file server's 
bindery, which lists active and inactive network entities. 
Because print servers are a special kind of bindery item, 
SAP registers NEB 1 01 via CPSOCKET, and if NEB 101 
is configured as a print server, SAP also registers the 



print server with the NetWare bindery. 

CPRINTSERVER is a custom implementation of a 
Novell print server application. This module provides 
self-generated print banners, user notification of com- 
s pletion and exception status, and transmission of print 
data and status commands to the print engine. This dif- 
fers from the Novell print server in that CPRI NTSERVER 
is dedicated to driving the local printer (i.e., printer 102 
in which NEB 101 is housed) and cannot drive any re- 
10 mote RPRINTERs. This program owns the print data 
channel for the duration of a print job. RPRINTER is a 
custom implementation of a Novell RPRINTER print ap- 
plication. This module is a slave application that is sent 
data by a Novell print server application elsewhere on 
is LAN 100. 

The TCP/IP protocol stack has User Datagram Pro- 
tocol (UDP), Reverse Address Resolution Protocol 
(RARP) and BootP support within. INTERRUPT is the 
interrupt handler for the TCP/IP task, while TiMERTICK 
20 is the timertick for UNIX TCP/IP networktasks. LPRI NT- 
SERVER is the TCP/IP print server application, and also 
owns the print data channel forthe duration of a print job. 

The CPSOCKET program runs for all protocol 
stacks. The program responds to requests for connec- 
ts tion, requests for data download, or requests for servic- 
es from remote utilities, and provides status and control 
to other tasks via interprocess communication. Because 
CPSOCKET typically owns the status and control chan- 
nel between NEB 101 and printer 102, it is the only task 
30 that has the ability to obtain printer status via the status 
channel. CPSOCKET is responsible for the network 
connection and packet contents between the Novellori- 
ented status and control utilities (CPNET), or between 
the UNIX-oriented status and control utilities (cpnet). 
35 MONITOR is a customized multi -tasking monitor 
which performs task creation, task destruction and mi- 
croprocessor dispatch. MONITOR also has memory 
management sub-modules MEMGET and MEMFREE. 
RESIDENT is a block of routines that provides generic 
40 services such as NVRAM read and write, FLASH code, 
ROM based debugger, hardware timer tick and other ba- 
sic features. POST is a power-on self-test module that 
checks the integrity of NEB hardware and software at 
power-up. 

45 Flash EPROM 174 also stores a Network Identifi- 
cation File ("NIF") block which stores board-invariant in- 
formation such as the Media Access Control ("MAC") 
address, which is unique for every network board : hard- 
ware configuration, board revision number and the like, 

50 as well as changeable information such as software ver- 
sion number. The information in the NIF block is used 
to ensure that flash EPROM 174 is not reprogrammed 
with an incompatible image. The NIF block is discussed 
in greater detail below in connection with Figure 1 3. 

55 All communication between NEB 1 01 and printer in- 
terface card 1 50 is executed via 32 KB shared SRAM 
200. Arbiter control logic 400, preferably a single 
100-pin ASIC, arbitrates between the two byte wide 
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memory accesses of printer interface microprocessor 
151 and the single byte wide memory accesses of NEB 
microprocessor 173, each of which is completely inde- 
pendent of the other. 

Generally speaking, the 8-bit data bus ol microproc- 
essor 173 on board NEB 101 communicates with bus 
control logic 41 0, while the 32-bit data bus ol microproc- 
essor 151 on board printer interface card 150 commu- 
nicates with bus control logic 420. Memory accesses 
from each bus are routed to shared memory arbiter 430, 
which determines which bus has priority (in accordance 
with an arbitration technique discussed below) and per- 
mits the bus with priority to access SRAM 200 via SRAM 
interface 440. Interrupt control register 450 is also ac- 
cessed through shared memory arbiter 430, to allow one 
microprocessor to interrupt the other. 

[NEB Functionality] 

Broadly speaking, NEB 101 is an interactive net- 
work circuit board which couples printer 102 to LAN 100, 
making printer 1 02 a responsive and interactive network 
member. NEB 101 receives print job information and 
status requests from LAN 100, transmits the print data 
and status commands to printer 102 for execution, re- 
ceives status information from printer 1 02, and transmits 
status information back to LAN 1 00. 

Thus, NEB 101 can not only perform RPRINTER 
remote printer services and PSERVER print server 
functionalities, but can also offer to network members a 
wide variety of status and control features. Through 
NEB 101, network members can access verbose 
amounts of status information stored in the NEB, such 
as the number of print jobs : the number of pages per 
job, the number of pages per minute, the time per job, 
the number of total pages per day, and the number of 
jobs per day. In addition, a great deal of control informa- 
tion may be provided from the network to printer 102, 
such as, for example, exercising the printer's front panel 
functions from a networked PC. 

All network traffic enters and leaves NEB 101 
through either BNC connector 302, which interfaces 
with network controller 510 through transceiver 171, or 
RJ-45 connector 301 , which interfaces directly with net- 
work controller 51 0. To eliminate the necessity for a user 
physically to position a switch, NEB 101 includes hard- 
ware and software which automatically detects which of 
the two connectors is coupled to the network. Network 
communications are transferred between the selected 
connector and the rest of the board, with network con- 
troller 510 along with NEB control logic 520 controlling 
the flow of data between the network traffic on the se- 
lected connector and microprocessor's 173 data bus. 

All software modules executed by microprocessor 
173 are stored in flash EPROM 174. Some low-level 
modules which are always needed, such as timer tick 
and NVRAM read, could be executed directly out of 
EPROM 174, but for the most part microprocessor 173 



does not execute software modules directly from flash 
EPROM 174, but rather selectively loads those modules 
that are needed into DRAM 175 for execution from 
DRAM. By virtue of this arrangement, it is possible to 

s select the specific modules that are retrieved from flash 
EPROM 174 for execution out of DRAM 175 so as to 
permit flexible configuration of NEB 101. 

For example, because many communication proto- 
col types may be broadcast on LAN 100, NEB 101 in- 
fo eludes, in flash EPROM 1 74, software modules for sup- 
porting multiple protocols. NEB 1 01 monitors all network 
traffic on the heterogeneous network to determine the 
protocol type or types in use, and loads the protocol 
stack or stacks which correspond to the protocols it de- 

15 tects into DRAM 175. 

Reprogramming flash EPROM 174 with a new im- 
age, which may include a new protocol stack, is also 
performed via DRAM 175. When a new image and a 
command to reprogram is received, such as a command 

20 received over the network or serial port connector 600, 
the software reprogramming module is loaded from 
EPROM 174 to DRAM 175. Microprocessor 173, exe- 
cuting this module from DRAM 175, confirms that the 
new firmware image is compatible with the configuration 

2S of NEB 101 , and reprograms EPROM 174 if compatibil- 
ity is confirmed, as described in more detail below. ■ 

Microprocessor 173, executing a loaded protocol 
stack out of DRAM 175, can send and receive network 
communications to and from other LAN members using 

30 that protocol. Print job data are received by network con- 
troller 510 and routed to microprocessor 173 through 
NEB control logic 520. Microprocessor 173 writes the 
print job data to shared memory SRAM 200, from which 
printer microprocessor 151 reads the data and operates 

35 print engine 160 in accordance therewith. In addition, 
each of microprocessors 173 and 151 can write mes- 
sage data to the other microprocessor in another portion 
of the shared memory. 

Access to the shared SRAM 200, as discussed 

40 above, is arbited by arbiter control logic 400 according 
to an arbitration priority technique. Arbiter control logic 
400 interleaves concurrent accesses of the two micro- 
processors with one another by allowing the microproc- 
essors access to the shared SRAM on a first -come first - 

45 serve basis, and presenting a wait state to the lower pri- 
ority processor while the higher priority processor takes 
its turn. In the case of an exact tie, microprocessor 173 
on NEB 101 is arbitrarily-given priority 

A large portion of shared SRAM 200 is configured 

so as a ring buffer, into which NEB microprocessor 173 
writes print data and out of which printer interface mi- 
croprocessor 151 reads it. As each processor writes or 
reads blocks of data, it updates respectively a ■put" 
pointer or a "get" pointer, stored elsewhere in SRAM 

55 200, to indicate the next location that the processor 
should access. 

By virtue of this arrangement, the writing processor 
can determine if there is available space in the memory 
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in which it may write, and the reading processor can de- 
termine whether there is remaining data to be read, by 
comparing the put and get pointers with one another. To 
reduce the amount of contention for shared memory be- 
tween the two processors, NEB microprocessor 173 
stops writing to memory (and accordingly stops reading 
and updating the pointers) at predetermined intervals, 
allowing printer interface microprocessor 151 sole ac- 
cess to the memory until it catches up, as described in 
more detail below. 

Serial port connector 600 is provided to allow NEB 
101 to be debugged from an external computer. Serial 
port connector 600 is coupled to NEB control logic 520, 
which accepts serial data from receive data pin 601 of 
serial port connector 600 and communicates the serial 
data bit-by-bit to microprocessor 173. Microprocessor 
1 73 configures NEB control logic 520 so that a start bit 
in the serial data activates the non-maskable interrupt 
of the microprocessor. Microprocessor 1 73 then assem- 
bles the data bits of the serial data into 8-bit words. In 
addition, NEB control logic 520 monitors the data bus of 
microprocessor 173, and passes a serial stream of the 
data presented thereon to transmit data pin 602 of serial 
port connector 600, all as described in more detail be- 
low. 

[Automatic Detection Of Network Hardware 
Connection] 

Network interface cards generally provide several 
different types of physical connections for connecting 
network cables to a LAN. NEB 101, for example, pro- 
vides a BNC connector 302, to which a 10Base-2 coax- 
ial cable may couple, and an RJ-45 connector 301 to 
which 1 0Base-T unshielded twisted pair (UTP) wire may 
couple. Other physical connections, such as an IBM 
data connector for a shielded twisted pair (STP) wire or 
an ST fiber optic connector for a fiber optic cable, are 
also possible. 

Typically, when a network interface card is connect- 
ed to a LAN through one of its several connectors, a 
user who establishes or changes the connection with 
the LAN must not only insert the LAN cable in the proper 
connector, but must also physically change the position 
of a hard switch, or "jumpers", so that data is routed to 
and from the proper connector 

Due to human error, however, it is possible for the 
user to forget to change the jumpers, or to put the jump- 
ers in an improper state with respect to the connection 
that has been established. In such a situation, of course, 
the card could not talk to the network at all. Isolating and 
correcting the problem results in an unacceptable waste 
of time, manpower and computer resources. A network 
interface card which automatically senses which con- 
nector has been connected to the LAN, and then routes 
data to and from that connector, would greatly stream- 
line the process for establishing and/or changing con- 
nections. 



_The present invention provides for such automatic 
detection of the hardware connection by testing, in turn, 
each of the connectors for an indication of network con- 
nectivity, and thereafter selecting one of the connectors 

s so that network communications can be transferred be- 
tween the selected connector and the on board proces- 
sor. Briefly, a network controller includes a first detector 
which detects whether the first connector is electrically 
connected to the network, and a first register, which the 

to processor can read, which stores a "jabber" bit which 
indicates whether the second connector is improperly 
terminated. A second register, which the processor can 
also read, stores a "good-link" bit which indicates that 
the first detector has detected that the first connector is 

15 electrically connected to the network., and a control reg- 
ister, to which the processor can write, stores a select 
bit. The control register outputs the selection signal in 
accordance with the select bit stored therein. 

The microprocessor executes a software-controlled 

20 selection process by ( 1 ) writing a select bit to the control 
register so as to cause output of a selection signal which 
selects the first connector (here, RJ-45 301 ), (2) reading 
the good-link bit from the second register, (3) maintain- 
ing the state of the selection bit when the good-link bit 

25 indicates electrical connection to the network, (4) writing 
a select bit to the control register so as to cause output 
of a selection signal which selects the second connector 
(here, UTP 302) when the good-link bit does not indicate 
electrical connection to the network, (5) reading the jab- 

30 ber bit from the first register, (6) maintaining the state of 
the select bit when the jabber bit does not indicate im- 
proper electrical termination of the second connector, 
and (7) repeating the selection process when the jabber 
bit indicates improper electrical termination of the sec- 

35 ond connector. This sequence allows the selection proc- 
ess to take place long after power-on of the board. Once 
a selection is made, it is maintained for the entire power- 
on cycle of the board. 

More particularly, and referring to Figure 8 : BNC 

40 connector 302 (through transceiver 171) and RJ-45 con- 
nector 301 are each coupled to selector 511 in network 
controller 510. Network traffic flows to and from micro- 
processor 173 through bus 181 via either BNC connec- 
tor 302 or RJ-45 connector 301 , depending on the state 

45 of selector 511. The position of selector 511 is deter- 
mined by the output of control register 521. 

When RJ-45 connector 301 is coupled to a LAN, an 
electric current will be present at the connector. Accord- 
ingly, network controller 510 includes a good-link detec- 

50 tor 512 which monitors RJ-45 connector 301 to deter- 
mine whether RJ-45 connector 301 is electrically con- 
nected to LAN 100. In the 83902 network controller, 
good-link detector 512 is configured as an open drain 
N-channel device. When an electrical current is detect- 

55 ed at RJ-45 connector 301 , the output of good-link de- 
tector 512 will be low and status LED 305 will be lit, in- 
dicating an electrical connection. If there is no current 
at RJ-45 connector 301 , on the other hand, the output 
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of good-link detector will go high, turning off status LED 
305. The output of the good-link bit is also fed to good- 
link register 522 in NEB control logic 520, which allows 
microprocessor 173 to read the state of the good-link 
signal. 

A BNC connector, such as BNC connector 302, will 
"jabber" unless the connector is properly terminated, 
such as, for example, when it is.coupled to a LAN with 
a T-type coaxial adapter. Network controller 510 in- 
cludes jabber detector circuit 51 3, which detects wheth- 
er there is jabbering at BNC connector 302 in a manner 
well known in the art, and writes the result of its detection 
into jabber register 514. Thus, jabber register 514 con- 
tains a bit which indicates whether BNC connector 302 
is properly terminated. The jabber bit can then be read 
by software. 

Microprocessor 173 controls the state of selector 
511 by executing a software module stored in flash 
E PROM 1 74 in a manner that will now be described with 
reference to the flowchart of Figure 9. After NEB 101 is 
powered-up (step S900), microprocessor 173 sets se- 
lector 51 1 to the RJ-45 position by writing a zero to con- 
trol register 521 via bus 181 (step S901). The program 
reads the state of good-link register 522 (step S902), 
and, if the bit stored in good-link register 522 is low (in- 
dicating an electrical current), the program determines 
that RJ-45 connector 301 is coupled to LAN 100, and 
exits, leaving selector 511 in the RJ-45 position 
(S903-S904). 

Because there is an inherent delay in the switching 
of the N-channel device which comprises good-link de- 
tector 51 2, it is necessary to give good-link detector 51 2 
ample time to detect an electrical connection. Accord- 
ingly, if the bit stored in good-link register 522 is high 
(indicating no electrical connection), the program will re- 
read good-link register 522 repeatedly, exiting and leav- 
ing selector 511 in the RJ-45 position if the bit is low for 
any of the reads (steps S905-S906-S902). If the bit 
stored in good-link register 522 is high after five hundred 
reads, however, the program sets selector 511 to the 
BNC position by writing a one to control register 521 
(step G907). 

The program then reads jabber register 514 (step 
S908). If the state of jabber register 51 4 is low (indicating 
that BNC connector 302 is properly terminated and a 
BNC connection is present), the program exits, leaving 
selector 511 in the BNC position (steps S909-S910). If 
the state of the jabber bit is high (indicating that BNC 
connector 302 is improperly terminated and thus not 
connected to LAN 100), the program returns to S901, 
resetting selector 511 to the RJ-45 position. The pro- 
gram then re-executes itself cyclically until either an RJ- 
45 or a BNC connection has been established. 

Thus, NEB 101 will continue to toggle between BNC 
connector 302 and RJ-45 connector 301 , checking after 
each toggle whether that particular connector is con- 
nected to LAN 100. By virtue of this arrangement, NEB 
101 is able to determine, at power-up (and until a con- 



nection is made), whether its BNC connector 302 or its 
RJ-45 connector 301 has been connected to the net- 
work, without requiring an operator to physically change 
a switch. Accordingly, the possibility that NEB 101 will 

5 attempt to communicate with LAN 100 through a con- 
nector that is not coupled to LAN 1 00 is eliminated. 

In the present embodiment, the selected hardware 
connection is maintained during the current power-on 
cycle. It is possible to implement- software which, after 

io a selection is made, senses when the hardware connec- 
tion is no longer valid, and then repeats the selection 
process, thereby permitting connectors to be changed 
during the current power-on cycle. This allows for dy- 
namic switching form one connection to another. 

15 

[Network Protocol Sensor] 

To ensure proper operation in a mu It i -protocol sys- 
tem, and to guard against making improper assump- 

20 tions concerning the protocol and frame type being used 
on a network, NEB 101 utilizes autoprotocol detection 
to determine frame types used by network traffic, and to 
correlate those frame types with a particular one of sev- 
eral different protocols available to NEB 1 01 . Specif ical- 

25 |y ( through use of the PRETASK module stored in flash 
EPROM 1 74, NEB microprocessor 1 73 is able to deter- 
mine which frame type is being used for network traffic, 
to correlate that frame type to one of several different 
protocols, and to load a protocol stack (such as I PX/SPX 

30 or TCP/IP) from flash EPROM 174 so as to carry out 
network communications using that protocol and the de- 
tected frame type. 

Figures 1 0 and 1 1 (a) through 1 1 (d) are used for de- 
scribing this process. Figure 10 is a flow diagram show- 

35 ing process steps executed by NEB microprocessor 173 
in accordance with the PRETASK software module load- 
ed in flash EPROM 174. PRETASK is similar to, though 
different from, the PRE SCAN software module which is 
described in co-pending application EP-A-0598510, 

40 "Method And Apparatus For Adaptively Determining 
The Format Of Data Packets Carried On A Local Area 
Network", the contents of which are incorporated herein 
by reference (representative's reference 2275230, US 
Serial No. 07/978,409). 

45 in step S1001, microprocessor 173 loads MLID 
(multi-link interface driver) from flash EPROM 174 into 
DRAM 175 and begins execution of MLID. As described 
above, MLID is the lowest level of software that commu- 
nicates to the network. MLI D thus acts as the direct soft- 

so ware interface to the network frame packets which are 
carried on the network wire. 

In step SI 002, microprocessor 173 loads LSL (link 
support layer) on top of MLID and begins executing LSL. 
LSL acts as a multiplexer between the low level MLID 

55 and various protocol stacks which may be loaded above 
it. In particular, LSL accepts registrations of any of the 
various frame types with which frame packets may be 
carried on the network. Thus, for example, in an Ether- 
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net environment, LSL will accept registrations of 802.2, 
802.3, EthernetJI and Ethernet_Snap, and in a Token- 
ring environment LSL will accept registrations for 802.5 
and Token_Ring_Snap. By registering a frame type with 
LSL, a software module above LSL instructs LSL to pro- s 
vide the module with all frame packets that match the 
registered frame type. 

In step S1003, microprocessor 173 loads PRE- 
TASK on top of LSL. As mentioned above, PRETASK is 
responsible for identifying what frame types are associ- io 
ated with the various protocols in which NEB 101 is 
adapted to communicate. In step S1 004, PRETASK reg- 
isters to receive from LSL all frame types that are sup- 
ported by MLID. Thus, in the Ethernet environment of 
the present embodiment, PRETASK registers 802.2, is 
802.3, Ethernet_l! and Ethernet_Snap with LSL, there- 
by instructing LSL to provide PRETASK with all frame 
packets which match any of the registered frame types. 

Flow then advances to step S1005 in which MLID 
and LSL monitor the network for any traffic. Specifically, 20 
in step S1005, the network is monitored for broadcast 
traffic meaning that the destination of the traffic is un- 
specified (i.e., "to anyone"). Ordinarily, broadcast traffic 
is identified by a global specification for the destination 
MAC address, for example 12 hexadecimal F's in se- 25 
quence. Until LAN broadcast traffic is detected, PRE- 
TASK does nothing. 

At this point in PRETASK's execution, the relation- 
ship of the various software modules is as depicted in 
Figure 11(a). As seen there, it is possible for multiple 30 
network devices, such as devices 182,. 183, 184 and 
185, each of which runs a different protocol using a dif- 
ferent frame type, all to be connected to a single LAN 
100. In Figure 11(a), device 182 is a Novell device run- 
ning an IPX/SPX protocol using an 802.2 frame type; 35 
device 183 is a UNIX network device running a TCP/IP 
protocol using an EthernetJI frame type; device 184 is 
a Macintosh device running an EtherTalk protocol using 
an Ethernet_Snap frame type; and network device 185 
is an unidentified frame and protocol device using an 40 
802.3 frame type. Of course, the combinations shown 
in Figure 11 (a) are illustrative only, and it is possible, for 
example, for a Novell IPX/SPX to use an 802.3 frame 
type or any of the other frame types. The only require- 
ment is that each protocol is associated with one and *s 
only one frame type. 

NEB 101 is also connected to LAN 1 00 and includes 
LSL 187 loaded on top of MLID 186. PRETASK 188 is 
shown as having registered each of the different frame 
types which may be broadcast on LAN 100. Thus, as 50 
shown in Figure 11(a), PRETASK 188 has registered 
802.2 at 189, EthernetJI at 190, Ethernet_Snap at 1 91 , 
and 802.3 at 192. 

When LAN broadcast traffic is detected, flow ad- 
vances to step S1006 in which LSL provides the frame ss 
packet to PRETASK. In step S1 007, PRETASK decodes 
the frame's protocol header so as to identify the protocol 
in use by that frame packet. The offset to this header 



varies depending on the frame type the protocol is using. 
The following table includes some examples of hexa- 
decimal values and the protocol headers that identify the 
different protocols: 



Hexadecimal Value 


Protocol Type 


0800 


IP 


0806 


. ARP 


809b 


EtherTalk 


8137 


IPX/SPX 



Figure 11(b) illustrates this sequence. As seen in 
Figure 11(b), network device 182 has issued a broad- 
cast frame packet using an 802.2 frame type. Since 
PRETASK has registered, at 189 as shown in Figure 11 
(a), 802.2 with LSL, LSL provides the frame packet to 
PRETASK. PRETASK decodes the frame's protocol 
header using the above table so as to determine the pro- 
tocol in use by that frame type. 

Reverting to Figure 10, in step S1008, PRETASK 
de-registers the frame type just received from LSL. 
Thus, as shown at 1 89a in Figure 1 1 (b), PRETASK has 
de-registered 802.2. 

While step S1008 shows de-registration in all cas- 
es, there are some cases in which it is more preferable 
not to de-register. Particularly, each different protocol 
has associated with it a list of allowable frame types. 
Examples of allowable frame types for IPX/SPX and for 
TCP/IT are as follows: 



IPX/SPX 


TCP/IP 


EthernetJI 
Ethernet_Snap 
802.2 
802.3 


EthernetJI 
Ethernet_Snap 



As is evident from the above list, it is possible for 
two of the frame types (EthernetJI and Ethernet_Snap) 
to be used by different protocols. It should also be noted 
that it is permissible for the same frame type to be used 
by different protocols on the same LAN. Thus, in a pre- 
ferred mode, de-registration in step S1008 is not per- 
formed when the frame type received by PRETASK in 
step S1006 can be used by a protocol that has not al- 
ready registered with LSL (see step S1010, below). This 
preferred mode allows detection and operation of all 
protocqls permissible on the LAN, since even later-re- 
ceived frame types for a protocol different from those 
already registered can be properly detected and proc- 
essed by PRETASK so as to load that different protocol. 

In step S1009, PRETASK loads the protocol stack 
that corresponds to the protocol decoded in step S 1 007. 
In the example being used in Figure 11(b), since an 
IPX/SPX protocol is decoded, PRETASK loads the 
IPX/SPX protocol stack from flash EPROM 174. Before 
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loading, the protocol stack is initialized with the frame 
type, here 802.2, just received from LSL 

In step S1010, the newly-loaded protocol stack reg- 
isters itself with LSL, as shown, for example, in Figure 
11 (c). As seen there, the IPX/SPX protocol stack regis- 
ters 802.2 with LSL. By registering, and as described 
above, IPX/SPX informs LSL to provide all frame pack- 
ets matching the registered frame type (here, 802.2) to 
the newly-loaded protocol stack. 

PRETASK then returns to step S1005 so as to con- 
tinue monitoring the network for broadcast traffic. If LSL 
encounters frame packets which match the remaining 
frame types registered by PRETASK, LSL provides 
those frame types to PRETASK for processing in ac- 
cordance with Figure 10. Thus, as additional frame 
types are encountered, such as a frame type associated 
with a TCP/IP protocol, those frames are processed by 
PRETASK so as to load the appropriate protocol stack 
from flash EPROM 174. 

Meanwhile, as shown in Figure 11(d), since a pro- 
tocol stack has been loaded, it now begins to operate 
on the network. Specifically, whereas PRETASK was 
completely passive and did not broadcast any network 
communications, IPX/SPX broadcasts its associated 
SAP requests. Other protocol tasks loaded by PRE- 
TASK would broadcast their associated requests. For 
example, if a TCP/IP protocol stack were loaded then 
that protocol stack would broadcast RARPs so as to ob- 
tain its address from the nearest network server. 

[Smart Flash] 

As local area networks grow more complex, it be- 
comes necessary to upgrade network interface cards, 
such as NEB 101, with the most current technologies 
available. Thus, while NEB 101 is shipped with opera- 
tional software, that software can be reprogrammed 
subsequently over LAN 100. For example, from the net- 
work administrator's PC 103, the network administrator 
can remotely alter the ROM firmware image in flash 
EPROM 174 by downloading new data, which may con- 
tain for example patch codes, manufacturing test rou- 
tines, entire firmware updates, and different language 
versions. 

A typical PC may be connected to more than one 
LAN. For example, as shown in Figure 12 : PC 103 is 
connected to LAN 100, which is an Ethernet LAN, and 
to LAN 193, which is a Token-ring LAN, and may in fact 
function as the network administrator's PC for both net- 
works. Each of the LANs may in turn be connected to 
several printers, each of which houses an individual 
NEB. Other reprogrammable devices might also be con- 
nected to one or both of the LANs. Thus, there are mul- 
tiple NEBs, or other devices, which the network admin- 
istrator can potentially reprogram. 

To reprogram a particular NEB, the network admin- 
istrator from PC 1 03 activates a program that scans the 
network bindery to identify suitable flash targets from all 



network devices connected to the network. Suitable 
flash targets include all NEB-like devices which have 
flash capabilities and include Ethernet devices and To- 
ken-ring devices. The network administrator selects one 

s of the devices for reprogramming and establishes net- 
work communication with that device. The flash EPROM 
on board then reprograms itself with the new image. 

Because the network administrator may be admin- 
istrating two or more networks, each of which has sev- 

10 eral reprogrammable boards connected to it, the admin- 
istrator must be certain that the proper image is sent to 
the targeted NEB. Thus, in the case where the network 
administrator wishes to reprogram flash EPROM 1 74 on 
NEB 101 (where the NEB is connected to an Ethernet 

is LAN), he must be certain that the image he sends is an 
Ethernet image, and that it is compatible with other as- 
pects of NEB 101. 

The results of downloading an incompatible image 
can be devastating. For example, if the network admin- 

20 istrator erroneously downloads a Token-ring image to 
NEB 101, and NEB 101 subsequently reprograms its 
flash EPROM 174 with that image, then NEB 101 will no 
longer be able to communicate on Ethernet LAN 100 at: 
all. This means that NEB 101 could not even be repro.-. 

25 grammed over LAN 100; it is, quite literally, a "dead" 
board as far as the Ethernet LAN is concerned. Other 
incompatibilities, such as, for example, incompatibilities 
in the host interface configuration (the type of interface 
between the NEB and the peripheral in which it is 

30 housed), product configuration (the NEB's board type), 
processor configuration (the type and speed of the proc- 
essor on board), and memory configuration (the size 
and erasability of the various on board memories), can 
result in problems as well. Thus, where there are prior 

35 generations of a product, flashing software which works 
only with newer generations will also result in a "dead" 
board. 

To prevent such disastrous results in the case 
where an incompatible image is downloaded, NEB 101 

40 includes a software code which ensures that the down- 
loaded image is compatible before actual reprogram- 
ming occurs. More particularly, flash EPROM 174 in 
NEB 101 stores a current program image which includes 
a network information file (NIF) block which contains 

45 configuration information for NEB 101, and a software 
module for reprogramming flash EPROM 174. Micro- 
processor 173 sends and receives network communi- 
cations, and when a new program image is received 
over the network, microprocessor 173 downloads the 

50 new image into DRAM 175, confirms that the new pro- 
gram image is compatible with the configuration infor- 
mation in the NIF block, and reprograms flash EPROM 
174 only in the case where compatibility is confirmed. 
In greater detail, the NIF block contains permanent, 

55 adapter specific configuration information, and is unique 
for each individual NEB. In a preferred embodiment, the 
NIF block occupies 32 bytes of memory space in flash 
EPROM 41 3, and is divided into 4 banks of 8 bytes each. 
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As shown in Figure 13, the NIF block includes a MAC 
address information bank, a board version and identifi- 
cation information bank, a component identification in- 
formation bank and a general information bank. 

The MAC address information bank, as the name 
implies, stores the board's unique MAC address. The 
board verification and identification information bank is 
subdivided into four smaller banks. Because network in- 
terface cards other than the NE B may be coupled to the 
LAN as well, a product category bank identifies the type 
of product coupled to the LAN and a board revision bank 
identifies the product's revision number. 

The network physical medium bank is further sub- 
divided into a physical network bank, which identifies the 
physical medium on which the board is used (such as, 
for example, Ethernet, Token-ring or FDDI) while the 
supported connectors block identifies the types of phys- 
ical connectors the board supports (such as, for exam- 
ple, lObaseT, 10base2 and 10base5 in the case of an 
Ethernet network, and UTP and STP in the case of a 
Token-ring network). In the host interface method bank, 
the type of interface to the peripheral that houses the 
board (such as printer 102 in the case of NEB 101) is 
identified. Examples of such interface types include 
shared RAM, small computer system interface (SCSI), 
standard parallel interface, RS-232C serial interface 
and Centronics parallel interlace. 

The component identification information bank is 
also subdivided into several smaller banks. These 
banks identify the sizes and granularities of the ROM, 
DRAM and NVRAM on the board, as well as the erasa- 
bilty of the ROM. In addition, the network controller 
(DP83902 chip in the case of Ethernet and TI380C25 in 
the case of Token-ring) and host controller (arbited 
shared RAM, NCR53C90A SCSI controller or 
NCR53C80 SCSI controller) are identified. In the CPU 
identification bank, the type of processor and the clock 
speed are stored. Finally, the general information bank 
can store other data identifying additional configuration 
attributes of the board such as hardware revision level. 

Referring to Figure 14, a reprogramming of flash 
EPROM 174 of NEB 101 begins when the CPFLASH 
program on the network administrator's PC scans the 
bindery (step S1401) and presents a list of potential 
flash targets to the administrator. The administrator se- 
lects a target (step SI 402) and CPFLASH establishes 
communication with the target and downloads the new 
firmware image over LAN 100 where it is stored in the 
NEB's DRAM 175 (step SI 403). 

Once the new image is downloaded into DRAM 1 75, 
NEB microprocessor 173 deactivates the protocol stack 
that it is executing, since it is, at least potentially, about 
to be programmed, and cannot engage in network com- 
munications during that time (step S1404). Microproc- 
essor 1 73 next copies the current NIF block from flash 
EPROM 174 to DRAM 175 (step 1405) and begins ex- 
ecuting the software reprogramming module. 

The software reprogramming module then performs 



image compatibility checks, referencing the information 
stored in the current image NIF block (which has been 
copied to DRAM 175), and comparing thai information 
with the information stored in the new firmware image 

5 NIF block, to ensure that the new image is compatible 
(step S1406). Because the NIF block contains a great 
deal of information about NEB 101 , a variety of checks 
are possible to determine such compatibility. 

A first compatibility check includes a network media 

io configuration check to determine if the new image is of 
the correct network medium type (e.g., Ethernet or To- 
ken-ring) by referencing the data stored in the physical 
network bank of the NIF block. Similarly, a second com- 
patibility check includes a host interface configuration 

is check to determine if the new image is an image for in- 
terfacing with the proper host (e.g., shared RAM or SC- 
SI) by comparing the data stored in the host interface 
method and host interface controller banks of the NIF 
block with the new image. 

20 a third compatibility check includes a product con- 
figuration check that is performed by referencing the 
product category and board revision banks of the NIF 
block and comparing that data with the new image to 
determine whether the new image is for the type of 

25 board on which the EPROM is housed. Also, a proces- 
sor configuration check can be performed by referenc- 
ing the CPU bank of the NIF block to determine whether 
the new image is compatible with the on board micro- 
processor. In addition, a memory configuration check 

30 can be performed by comparing the data stored in the 
ROM, DRAM and/or NVRAM banks of the NIF blocks 
with the new image to determine whether the new image 
is compatible with the board's memory. Other compati- 
bility checks, using other information stored in the NIF 

35 block, are also possible. 

If it is determined that the new image is incompati- 
ble, the current protocol stack is reactivated (steps 
S1407-S1408) and an error is reported to the network 
administrator's PC 103 over LAN 100, advising that an 

40 attempt has been made to reprogram NEB 101 with an 
incompatible image (step S1409). 

On the other hand, if the new image is compatible, 
then board-invariant portions of the NIF block of the new 
image are replaced with the corresponding portions of 

45 Nl F block of the current image, in order to preserve any 
board specific information (such as the MAC address 
and board revision number) contained therein (steps 
S1407-S1410). The program then erases the current 
image from flash EPROM 174, and reprograms flash 

50 EPROM 174 with the new image stored in DRAM 175, 
which now includes the original NIF block. 

By virtue of this arrangement, microprocessor 173 
will never reprogram flash EPROM 174 with an incom- 
patible image, even in the case where an incompatible 

55 image was erroneously downloaded over LAN 100. 
Rather, in the case where a network administrator does 
attempt to reprogram NEB 101 with an incompatible im- 
age, NEB 101 will send a message back to the network 
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administrator, advising him of the incompatibility. Ac- 
cordingly, a fail-safe measure against such human er- 
rors is provided in an inexpensive, efficient way. 

[Arbitration Device] 

Figures 15 through 17 are views for explaining ar- 
bitration of shared SRAM 200 in response to access re- 
quests from printer interface card 150 or from on-board 
NEB microprocessor 173. 

Figure 1 5 shows printer address/data bus (A/D bus) 
701 , print address latch enable (ALE) signal 702, printer 
data enable (DEN) signal 704, printer clock line 705 and 
printer ready signal 706. These signals are all received 
via printer interface connector 170 from printer interface 
card 150. Specifically, for example, A/D bus 701 is the 
A/D bus for printer microprocessor 151 mounted on 
printer interface card 150. Printer ALE signal 702 is a 
signal indicating when valid address information is car- 
ried on A/D bus 701, and printer DEN signal 704 is a 
signal indicating when valid data information is carried 
on A/D bus 701 . Printer clock 705 is the main clock sig- 
nal for printer microprocessor 1 51 , and printer ready sig- 
nal 706 is a signal which, when false, indicates to mi- 
croprocessor 1 51 that a memory access is not complete 
and that microprocessor 151 should insert wait states 
until memory access is complete. 

Also shown in Figure 15 is NEB address/data bus 
(A/D bus) 711, NEB ALE 712, read and write signals 
(WR and RD) 714, NEB clock 71 5 and NEB ready signal 
716. NEB A/D bus 711 is the main address bus for mi- 
croprocessor 173, and carries address and data infor- 
mation for all components mounted on NEB 101 . NEB 
ALE signal 712 is a signal indicating when the valid ad- 
dress information is available on A/D bus 711 , read and 
write signals 714 are signals indicating when valid data 
information is available on A/D bus 711 and, in addition, 
whether to read or to write that data, NEB clock 715 is 
a main clock signal supplied by crystal oscillator 172, 
and NEB ready signal 71 6 is a signal which, when false, 
indicates to N E B microprocessor 1 73 that a memory ac- 
cess is not yet available and that microprocessor 1 73 
should insert wait states until memory access is availa- 
ble. 

Printer microprocessor 151 and NEB microproces- 
sor 173 communicate, as mentioned above, through 
shared SRAM 200. Access requests for shared SRAM 
200 are issued by microprocessor 151 and microproc- 
essor 173 on A/D buses 701 and 711, respectively, and 
are arbitrated by arbiter control logic 400, as described 
above. More particularly, and as described above with 
respect to Figure 6, arbiter control logic 400 includes 
bus control logic 410 for controlling the bus accesses 
on NE B A/D bus 711, bus control logic 420 for controlling 
bus traffic on printer A/D bus 701 , shared memory arbi- 
ter 430 for arbitrating between access requests on A/D 
bus 701 and A/D bus 711, SRAM interface 440 for inter- 
facing printer A/D bus 701 and NEB A/D bus 711, re- 



spectively, to address and data buses for SRAM 200. 
Each of those sections is described in more detail below. 

Bus control logic 410 includes latch 7 1 7 which latch- 
es address information on NEB A/D bus 71 1 in response 

5 to NEB ALE signal 71 2 so as to provide latched address 
information 719. Decoder 720 decodes latched address 
information when read or write signal 714 is active so 
as to provide a NEB request signal (NREQ signal) 721 
in the event that address information on NEB A/D bus 

10 711 corresponds to address space of shared SRAM 
200. 

Likewise, bus control logic 420 includes latch 722 
which latches address information on printer A/D bus 
701 when printer ALE signal 702 is high so as to provide 

15 latched address information 724. A decoder 725 is re- 
sponsive to latched address information and outputs a 
printer request signal (PREQ) 726 when printer DEN 
signal 704 is active in the event that the latched address 
information corresponds to address space of shared 

20 SRAM 200. 

Shared memory arbiter 430 includes synchroniza- 
tion circuitry to synchronize the PREQ and NREQ ac- 
cess request signals to a common clock, here NEB clock 
71 5, a delay circuit which inserts a fractional clock delay 

25 jnto one of the request signals, a hold off circuit which 
grants access to a first-received request signal and 
holds off access to later-received access requests, and 
a re-synchronization circuit. Specifically, both NREQ 
721 and PREQ 726 are provided to synchronization cir- 

30 cuits which are both synchronized to NEB clock 715 so 
as to synchronize both access requests to a common 
clock. In the specific instance illustrated herein, PREQ, 
which is inherently synchronized to its own printer clock 
signal 705 is synchronized to NEB clock signal 715. De- 

35 (ay 729 is inserted into one of the access request sig- 
nals, here into the access request signal from the printer, 
so as to produce offset request signals. The delay circuit 
inserts a fractional clock delay, such as a one-half clock 
delay, so as to ensure that even if both access requests 

40 are issued at exactly the same time, one access request 
will reach hold off circuit 730 before the other. 

Hold off circuit 730 outputs first and second access 
grant signals PACK and NACK, in correspondence to 
the first and second access request signals. Exactly one 

45 of the first and second access grant signals is activated 
in correspondence to which of the first and second offset 
request signals is received first. The other (or later-re- 
ceived) offset request signal is held off until processing 
of the first-received access request signal is complete. 

50 To indicate to the held-off microprocessor that access is 
denied, a not-ready signal is issued. For example, in a 
case where a NEB access request is received after a 
printer access request, hold off circuit 730 grants access 
to the printer and holds off access by the NEB. In that 

55 case, NEB ready signal 71 6 is de-asserled indicating to 
microprocessor 1 73 to insert wait states until access is 
granted. Conversely, if a NEB access request is re- 
ceived before a printer access request, hold off circuit 
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730 grants access to the NEB and holds off access to 
the printer. In that case, hold off circuit 730 delays printer 
ready signal 706 to indicate to microprocessor 151 to 
insert wait states until access is granted. 

The PACK access grant signal for the printer is then £ 
fed to the re -synchronization circuit 731 in which the de- 
synchronized signal is re-synchronized with its own 
clock. The re-synchronized signal is designated as 
FPACK. The re-synchronized access grant signals, 
FPACK and NACK, are then fed to SRAM interface 440 10 
which provides proper interface between the microproc- 
essor that has been granted access and the shared * 
SRAM 200. 

Shared memory arbiter 430 is preferably construct- 
ed from D-type flip flops and standard logic circuitry. One is 
preferred construction is shown in Figure 16. As seen 
there, access request signal 726 from the printer is fed 
to a synchronizing D-type flip flop 728a which is clocked 
by NEB clock signal 715 and subsequently to a second 
D-type flip flop 728b. At the same time, access request 20 
signal 721 from the NEB is fed to the input of a D-type 
flip flop 727a and subsequently to a second D-type flip 
flop 727b. These two flip flops 727a and 727b are pro- 
vided so as to ensure suitable synchronization and de- 
lay of access request signal 721. Trailing-edge-trig- 25 
gered D-type flip flop 729 is provided so as to insert a 
VA> clock delay into access request signal 726 from the 
printer. Output of flip flop 729 is held low by reset signal 
732 which is provided in the event that an access grant 
signal has already been provided to the NEB (i.e., the 30 
NACK signal is high). On the other hand, if access has 
not yet been granted to the NEB, then any access re- 
quest signals from the printer are clocked through so as 
to form the PACK signal. The PACK signal is sent to re- 
synchronization flip flop 731 which is clocked by printer 35 
clock 705. At the same time the PACK signal is provided 
to NAND gate 734 which operates in conjunction with 
the clocked NEB access request signal. If access has 
been granted to the printer, then NAND gate 734 en- 
sures that access is not granted to NEB, even if request- 40 
ed, until PACK goes low. 

By virtue of the arrangement shown in Figure 16, 
although the hold off circuit 730 outputs first and second 
grant signals, only exactly one of those first and second 
grant signals is activated at any one time. That is, if ac- 45 
cess is granted to the printer, then access is held off to 
the NEB; conversely, if access is granted to the NEB, 
access is held off to the printer. 

Returning to Figure 15, SRAM interface 440 re- 
ceives the re-synchronized printer access grant signal so 
FPACK as well as NEB access grant signal NACK and, 
based on which of those signals is active, coordinates 
access between either printer microprocessor 151 or 
NEB microprocessor 173 to shared SRAM 200. 

More particularly, as shown in Figure 15, the NEB ss 
access grant signal NACK is provided to multiplexer 735 
which selects either latched NEB address information 
719 or latched printer address information 724 in ac- 



cordance with the NACK signal and provides the select- 
ed address information onto internal address bus 736. 
In the case that NACK is active, then multiplexer 735 
provides all thirteen (13) bits of latched NEB address 
information 719 onto internal address bus 736. On the 
other hand, if NACK is not active (i.e., the printer has 
access), then multiplexer 735 provides twelve of the thir- 
teen bits of latched printer address information 724 onto 
internal address bus 736. The thirteenth bit, here AO, is 
provided by generator 747, in a manner described be- 
low. 

Buffer 737 buffers address information from internal 
address bus 736 onto SRAM address bus 740. Buffer 
737 is activated from the output of OR gate 739. OR 
gate 739 accepts as one of its inputs the NEB access 
grant signal NACK; accordingly, as soon as NACK goes 
high buffer 737 buffers the address information on inter- 
nal address bus 736 onto SRAM address bus 740. 

In accordance with whether a read or a write is re- 
quested, that is, in accordance with the status of the 
read or write signal 714, SRAM.200 either receives or 
puts data information onto its data bus 741 . That data 
information is transferred via bi-directional buffer 742 
onto internal data bus 744. Bi-directional buffer 742 is 
activated by the output from OR gate 745 which accepts 
as one of its inputs NEB acoess grant signal NACK. Ac- 
cordingly, when NACK goes high, the output of OR gate 
745 goes high which in turn allows transfer of data in- 
formation from SRAM data bus 741 to internal data bus 
744. Data information on internal data bus 744 is trans- 
ferred to NEB A/D bus 711 by bi-directional buffer 746 
which is activated by the NEB access grant signal 
NACK. Since the NEB access grant signal NACK de- 
rives itself, ultimately from decoder 720 which is trig- 
gered by read or write signal 714, timing of data infor- 
mation on NEB A/D bus 711 is proper inasmuch as bus 
711 no longer expects valid address data to appear on 
it but rather now expects valid data information to ap- 
pear on it. 

Thus, in summary, when the NEB is granted access 
to shared SRAM 200, latched address information from 
latch 717 is buffered onto SRAM address bus 740 via 
multiplexer 735 and buffer 737, and data information is 
buffered to (or from) NEB A/D bus 7 1 1 from (or to) SRAM 
data bus 741 via bi-directional buffers 742 and 746. 
When access operations for the NEB are complete, any 
held off access requests from the printer are processed. 

In the event that printer microprocessor 151 has 
been granted access to shared SRAM 200, then even 
though printer microprocessor 1 51 uses the same 1 3-bit 
wide address that NEB microprocessor 173 uses, be- 
cause microprocessor 151 has a data bus width which 
is different than that of SRAM 200 Supper- and lower- 
byte buffers are required so as to resolve these bit-width 
differences. More particularly, as described above, 
printer microprocessor 151 is a 32-bit Intel 80960KB 
RISC microprocessor which, through convention, com- 
municates with external devices through 16-bit wide 
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shared RAM data access. Resolution of 16-bit accesses 
to internal 32-bit format of printer microprocessor 151 is 
left to the printer microprocessor. However, resolution 
of 1 6-bit data accesses from microprocessor 1 51 to 8-bit 
wide shared SRAM 200 is left to SRAM interface 440 s 
and the above-mentioned upper byte and lower byte 
buffers. That structure is described in more detail below. 

More particularly, for address information latched in 
latch 722, multiplexer 735 transfers twelve of the thir- 
teen bits onto internal address bus 736. The thirteenth 10 
bit, here AO, is provided from generator 747. Generator 
747 is activated by lower strobe output 750 and upper 
strobe output 752, both from strobe generator 751. 
Strobe generator 751 is arranged so as to provide two 
consecutive signals, lower strobe 750 and upper strobe *s 
752, in response to receipt of an FPACK access grant 
signal from shared memory arbiter 430. Lower strobe 
signal 750 is provided to generator 747 which, in turn, 
provides a binary zero bit for the thirteenth address bit 
to multiplexer 735. Multiplexer 735 selects these thir- 20 
teen address bits onto internal address bus 736. The 
address information on internal address bus 736 is, as 
mentioned above, latched onto SRAM address bus 740 
via buffer 737. Bufler 737 is activated by output of OR 
gate 739 which includes as its inputs upper strobe 752 25 
and lower strobe 750. Thus, in response to each con- 
secutive upper and lower strobe signal 750 and 752, OR 
gate 739 outputs a signal to buffer 737 which causes 
address information on internal address bus 736 to be 
transferred to SRAM address bus 740. 30 

Upper address strobe 752 is also provided to gen- 
erator 747 which generates a binary one bit for the thir- 
teenth address bit to multiplexer 735. Multiplexer 735 
selects those thirteen bits onto internal address bus 736. 
That modified address information is, in sequence with 35 
receipt of upper strobe 752 by OR gate 739, transferred 
to address bus 740 of SRAM 200. 

Handling of data information depends on whether a 
read or a write is requested by printer microprocessor 
151. In the case of a write, strobe generator 751 pro- 40 
vides lower strobe signal 750 to buffer 754 which buffers 
the lower byte of data information on printer A/D bus 701 
to internal data bus 744. That data information is buff- 
ered to SRAM data bus 741 via bi-directional buffer 742 
which is activated by output of OR gate 745 which, in *s 
turn, accepts as one of its inputs the printer access grant 
signal FPACK. Thus, the lower byte of data information 
on printer A/D bus 701 is transferred via buffer 754 onto 
internal data bus. 744 and thence to SRAM data bus 
741. so 

The upper byte of data information on printer A/D 
bus 701 is buffered by buffer 755 which is activated by 
upper strobe signal 752 from strobe generator 751 . As 
before, that upper byte of data information is transferred 
onto internal data bus 744 and thence to SRAM data 55 
bus 741 via bi-directional buffer 742. 

When printer microprocessor 151 requests a read 
of SRAM data, lower strobe signal 750 and upper strobe 
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signal 752 are delayed by respective delays 756 and 

757 and the delayed strobes control respective latches 

758 and 759. Those latches latch respective lower and 
upper bytes provided from data bus 741 of SRAM 200, 
assemble the upper and lower bytes onto printer A/D 
bus 701 , and provide the assembled data information to 
printer microprocessor 151 . 

Thus, in summary, when printer microprocessor 
151 is granted access to shared- SRAM 200, address 
information latched in latch 722 is provided to the ad- 
dress bus of SRAM 200, and data information written to 
(or read from) SRAM 200 is resolved by lower and upper 
buffers 754 and 755 into data information for SRAM data 
bus 741 (or assembled from data information from data 
bus 741 by latches 758 and 759). When access by print- 
er microprocessor 151 is complete, any held off access 
requests from the NEB are then processed. 

OR gate 760 outputs a chip select signal 761 to 
shared SRAM 200. Inputs to OR gate 760 are lower ad- 
dress strobe 750, upper address strobe 752 and NEB 
access grant signal NACK. Thus, in response to any of 
those signals, chip select signal 761 is issued. 

Figure 17 is a timing diagram showing timing of sig- 
nals provided to arbiter control logic 400. Specifically, 
on the printer side and as discussed above : arbiter con- 
trol logic 400 is provided with printer clock 705, printer 
ALE signal 702, printer A/D bus 701 , printer DEN signal 
704 and printer ready signal 706. 1 n response to address 
information on printer A/D bus 701 which corresponds 
to address space in shared SRAM 200, which is valid 
and latched when printer ALE signal 702 goes high, and 
which thereafter generates a printer request signal 726 
(Figure 15) when printer DEN signal 704 goes low, hold 
off circuit 730 in arbiter control logic 400 generates^ 
printer ready signal 706 to cause printer microprocessor 
151 to generate wait states until access to SRAM 200 
has been granted and valid data appears on printer A/D 
bus 701 , as indicated when printer DEN signal 704 goes 
high. 

On the NEB side, in response to address informa- 
tion on NEB A/D bus 711 which corresponds to address 
space in SRAM 200, which is valid and latched when 
NEB ALE signal 712 goes low, and which thereafter gen- 
erates a NEB request signal 721 when NEB write signal 
714 (not shown) goes low, a NEB ready signal 716 is 
generated until access to SRAM 200 is granted and val- 
id data appears on NEB A/D bus 711 . 

[Reducing Bus Contention In Shared Memory] 

As discussed above, arbiter control logic 400 is in- 
tegral to the design of NEB 101, in that it allows only one 
of the processors to access shared SRAM 200 at a given 
point in time. This prevents simultaneous access to the 
same memory cell, thereby preventing data corruption. 
However, the arbitration, by necessity, is performed on 
the entire memory array, and not on individual memory 
cells. Thus, one processor must wait while the other ac- 
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cesses the memory, even if the two referenced address- 
es are different with respect to one another. This can 
lead to very slow memory access times, particularly in 
the case where print data is being transferred from the 
network by NEB microprocessor 173 to printer interface 
microprocessor 151 via shared SRAM 200. 

Figure 18 shows how available memory in SRAM 
200 is divided in logical space. All data transferred from 
NEB 101 to printer 102, including print job data, com- 
mands and status requests, are written by NEB micro- 
processor 173 into printer data area 201, from where 
the data are read by printer interface microprocessor 
1 51 . Conversely, all data transferred from printer 102 to 
NEB 101 are written by printer interface microprocessor 
151 into message data area 202, from where the data 
are read by NEB microprocessor 173. 

As is shown in Figure 18, printer data area 201 is 
configured as a ring buffer, in which a linear memory 
array is addressed circularly so that addressing auto- 
matically restarts at the beginning when the end is 
reached. Such a memory structure requires two point- 
ers: a "put* 1 pointer which marks the next address in 
which data are to be written, and a "get" pointer marking 
the next address from which data are to be read. The 
values of these pointers are stored in SRAM 200 itself, 
in status message area 203. The sending processor 
controls the value of the put pointer, advancing it as it 
writes new data into the ring buffer, white the receiving 
processor controls the value of the get pointer, advanc- 
ing it as it copies data out. 

Data are written into the ring buffer in blocks of 256 
bytes, with the put and get pointers marking where the 
next block begins. For example, in Figure 18 : the put 
pointer points to block 2011 , indicating that that block is 
the next available space in memory in which NEB mi- 
croprocessor 1 73 is to write, while the get pointer points 
to block 201 2, indicating that that block is the next space 
in memory from which printer interface microprocessor 
151 is to read. Before writing a block of data into mem- 
ory, NEB microprocessor 173 reads the values of the 
put and get pointers from status message area 203, and 
compares them to determine whether there is available 
room in the ring. Similarly, printer interface microproc- 
essor 151 reads the values of the put and get pointers 
from status message area 203 and compares them to 
determine whether there is data to be read. 

Thus, in transferring data from one processor to an- 
other using a ring buffer, the receiving processor follows 
the sending processor "around the ring", reading out the 
data that has been written. Because the receiving proc- 
essor is limited by the speed of the printer it is driving, 
however, the sending processor generally writes data in 
faster than the receiving processor can read it out, and 
it is likely that, in a conventional system, the put pointer 
will loop around the ring and "catch up" with the get 
pointer that is behind it. In such a case, the sending proc- 
essor simply waits until memory space becomes avail- 
able in the ring. During that waiting time, in conventional 



sysiems the sending processor reads and compares the 
put and get pointers periodically to determine if space 
has become available. Such polling by the sending proc- 
essor slows down the receiving processor, since the 
s sending processor must access the shared memory to 
read the values of the pointers, which prevents access 
by the printer and degrades the performance of the en- 
tire system. 

In NEB 101 , bus contention is reduced by prevent- 
10 ing the put pointer from being ahead of the get pointer 
by more than a predetermined amount and then waiting 
until the get pointer catches up. The NEB does not poll 
shared SRAM 200 to determine when the get pointer 
catches up with the put pointer, but rather relies on an- 
is other device, here interrupt control register 450, to pro- 
vide notification of when the get pointer catches up. Spe- 
cifically, it is a feature of the printer interface that the 
print data can contain a command for the printer to gen- 
erate an acknowledgement to the NEB via interrupt con- 
20 trot register 450. The NEB inserts this command in the 
last block of print data that it sends to the printer, and 
uses the acknowledgement from interrupt control regis- 
ter 450 as a substitute for polling. Specifically, the NEB 
sends print data to the printer by (1 ) determining wheth- 
25 er there is available space in shared RAM for the print 
data by reference to a counter of outstanding acknowl- 
edgements, (2) if there is available space, reading the 
get and put pointers and determining whether the put 
pointer is equal to one of plural partition indices .which 
30 correspond to the number of partitions into which the 
ring buffer is divided, (3) writing a command requesting 
the receiving processor (the printer) to issue an ac- 
knowledgement in the case where the value of the put 
pointer is equal to one of the predetermined indices, (4) 
35 writing a block of print data into the shared memory at 
the location of the put pointer, and thereafter, (5) updat- 
ing the value of the put pointer. When NEB 101 writes 
a command requesting the printer to issue an acknowl- 
edgement, it updates the number of outstanding ac- 
40 knowledgements that it expects to receive from the 
printer by adding one to the counter of outstanding ac- 
knowledgements. When an acknowledgement is re- 
ceived from the printer, the counter of outstanding ac- 
knowledgements is reduced by one. The counter is not 
45 stored in shared SRAM 200, but rather is stored in 
DRAM 175 which is owned by NEB microprocessor 1 73 
and for which there is no problem of bus contention. Ac- 
cordingly, NEB 101 determines whether there is space 
available in the ring buffer by comparing the number of 
so outstanding acknowledgements stored in the counter to 
the number of partitions into which the ring buffer is di- 
vided. If the number of outstanding acknowledgements 
is greater than or equal to the number of partitions, then 
the ring buffer is full and NEB 101 does not write any 
55 additional print information to the ring buffer; instead, it 
waits until an acknowledgement is received which indi- 
cates that the printer has cleared out one partition of the 
ring buffer and that that partition is now available for new 
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print information. On the other hand, if the number of 
outstanding acknowledgements is less than the number 
of partitions, then there is still available space in the ring 
buffer. 

Figure 19 shows the procedure by which the send- 
ing processor on NEB 101 (i.e., NEB microprocessor 
173) writes data into shared SRAM 200. The process 
begins when a print job is received from the LAN (step 
S1 902). When the print job is received, NEB microproc- 
essor 173 determines whether there is space available 
in the ring buffer for print data. This is accomplished by 
counting the number of outstanding acknowledgements 
which are expected from the printer. More specifically, 
as mentioned above, it is possible for NEB microproc- 
essor 1 73 to insert commands mixed with the print data 
which cause the printer to issue an acknowledgement 
which is conveyed from the printer to NEB microproc- 
essor 1 73 via interrupt control register 450. NEB micro- 
processor 173 tracks the number of outstanding ac- 
knowledgements, that is, the number of commands is- 
sued for an acknowledgement minus the number of ac- 
knowledgements actually received. If the number of out- 
standing acknowledgements is less than the number of 
partitions into which the ring buffer has been divided 
(here, the ring buffer has been divided into two parti- 
tions), then space is available in the ring buff er for more 
print data; on the other hand, if the number of outstand- 
ing acknowledgements is equal to or greater than the 
number of partitions into which the ring buffer has been 
divided, then no more space is available and NEB mi- 
croprocessor 173 waits until acknowledgements have 
been received. 

Thus, in step S1903, NEB microprocessor 173 de- 
termines whether an acknowledgement has been re- 
ceived from the printer. If an acknowledgment has been 
received, flow branches to step S1904 in which the 
number of outstanding acknowledgements is updated. 
In any event, flow then advances to step S1 905 in which 
NEB microprocessor 173 determines whether space is 
available in the ring buffer for the print data received in 
step S1 902. As mentioned above, NEB microprocessor 
173 does not determine whether space is available by 
accessing the put and get pointers, since such accesses 
would cause needless bus contention. Instead, NEB mi- 
croprocessor 173 determines whether there is space 
available by comparing the number of outstanding ac- 
knowledgements to the number of partitions into which 
the ring buffer has been divided. If the number of out- 
standing acknowledgements is not less than the number 
of partitions, then no space is available in the ring buffer 
and flow returns to step S1903 until an additional ac- 
knowledgement is received. On the other hand, if the 
number of outstanding acknowledgements is less than 
the number of partitions, then space is available in the 
ring buffer and flow advances to step S1906. 

In step S1906, the put and get pointers are read 
from shared SRAM 200 from status message area 203. 
In step S1907, if the put pointer equals a partitioned in- 



dex^ that is, if the put pointer points to the end of a par- 
tition in the ring buffer, such as index A and index B in 
Figure 1 8, then NEB microprocessor 1 73 inserts a com- 
mand forthe printerto issue an acknowledgement. More 

5 specifically, if the put pointer is equal to one of the par- 
titioned indices, then flow branches to step S1908 in 
which the NEB microprocessor writes its next block of 
print data into the memory location indicated by the put 
pointer, but also includes in the block a command for the 

io receiving processor (i.e., printer microprocessor 151 ) to 
issue an acknowledgement. NEB microprocessor 173 
next updates the value of the put pointer (step S1909), 
and then updates the number of outstanding acknowl- 
edgements (step S1910). Flow then advances to step 

is S1 91 1 in which it is determined whether more print data 
needs to be sent to the printer. If more data needs to be 
sent, then flow returns to step S1 903 in which NEB mi- 
croprocessor 173 determines whether space is availa- 
ble in the ring buffer by reference to the number of out- 

20 standing acknowledgements. 

On the other hand, if in step S1 907 the put pointer 
is not equal to one of the partitioned indices, then flow 
continues at step S1912 in which NEB microprocessor 
173 simply writes its next block of print data into .the 

2B memory location indicated by the put pointer, updates 
the value of the put pointer (step S1 91 3) and continues 
on to step S1911 to determine whether more print data 
needs to be sent to the printer. 

The receiving processor issues acknowledgements 

30 when it reads from the shared memory the data block 
that includes that command. More particularly, and re- 
ferring to Figure 20, the receiving processor begins its 
data retrieval by reading the values of the get and put 
pointer from the shared memory (step S2001). If there 

35 is data to retrieve (step S2002), the receiving processor 
reads the block of data from the memory location indi- 
cated by the get pointer (steps S2002-S2004) and up- 
dates the value of the get pointer (step S2005). 

The receiving processor then executes any com- 

40 mands that were included in the data block (step 
S2006), such as, for example, a command to issue an 
acknowledgement. The receiving processor issues this 
acknowledgement as an interrupt to the sending proc- 
essor, which it generates by writing a bit to interrupt con- 

45 trol register 450 that is part of arbiter control logic 400. 
When the sending processor receives the interrupt, it 
updates its number of outstanding acknowledgements, 
as described above. 

Accordingly, when the ring buffer is partitioned into 

so two partitions, the sending processor writes blocks to 
only half of the ring buffer at a time, checks if the receiv- 
ing processor has finished reading the other half, and 
ceases to access the shared memory at each of the in- 
dices until the receiving processor catches up. In alter- 

55 native embodiments, the ring can be further divided into 
finer granularities in those situations where two ring seg- 
ments are insufficient. In those cases, as shown in Fig- 
ures 21 (a) through 21 (c), for example, additional indices 
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would be used. 

By virtue of this structure, the waiting of NEB micro- 
processor 173 will not hinder the reading of printer in- 
terface microprocessor 151, since NEB microprocessor 
173 will not be accessing the shared SRAM 200 at all $ 
at that time. This not only achieves a greater data 
throughput, since the printer interface microprocessor 
151 can accomplish its task more quickly, but also frees 
NEB microprocessor 173from having to poll the put and 
get pointers, allowing it to perform other work not involv- io 
ing shared SRAM 200. 

[Serial Port] 

Serial port connector 600, as mentioned above, is is 
provided for serial communications with external proc- 
essors, particularly a processor used in connection with 
debug services for NEB 101 . Specifically, via serial port 
connector 600, an external processor is able to retrieve 
debug information transmitted by NEB 101 when NEB 20 
1 01 is set to a debug state. That information can include, 
for example, status of internal NEB registers, status of 
network broadcasts and traffic on network interface 301 
(or 302, whichever is enabled), status of print informa- 
tion as well as print information being written to shared 25 
SRAM 200 and the like. 

Because serial port connector 600 is used in con- 
nection with debug services, it is imperative that serial 
communications over that port are responded to by NEB 
microprocessor 1 73, regardless of the interruptability of 30 
NEB microprocessor 173. For example, when reducing 
bus contention by waiting to write new print data into 
SRAM 200 until printer 102 issues an acknowledge- 
ment, as described above, it is possible for the printer 
erroneously to fail to issue such an acknowledgment. In 35 
those cases, the NEB microprocessor will loop continu- 
ously until an acknowledgement is received. Ordinarily, 
a processor in such a state is "locked-up" meaning that 
it does not respond to any interrupts; in this locked-up 
state it is ordinarily necessary to cycle power to the 40 
board. However, because this erroneous operation is 
precisely the kind of operation for which debug informa- 
tion is desired over serial port connector 600, it is im- 
perative that NEB microprocessor 173 be able to re- 
spond to such serial communications. 45 

The arrangement illustrated in the accompanying 
figures describes a serial port construction in which sig- 
nals on a receive channel are transmitted to the non- 
maskable interrupt (NMI) pin of NEB microprocessor 
173. A non-maskable interrupt feature is available on 50 
most modern-day processors, such as the Intel 80X86 
line of processors, and it provides a means for interrupt- 
ing the processor regardless of its current computing 
state. That is, when the NMI pin is activated, the proc- 
essor must respond to the interrupt regardless of other 55 
operations that are currently underway. 

More particularly, as shown in Figure 22, a serial 
port construction according to the invention includes 



NEB microprocessor 173 which includes a non-maska- 
ble interrupt (NMI) pin 1 731 and which is connected via 
bus 181 to NEB control logic 520, as described above. 
NEB control logic 520 includes address decode logic 
523 which decodes address signals on bus 181 and 
which provides access to internal registers in NEB con- 
trol logic 520. Particularly, three registers are concerned 
here: transmit register 524, receive register 525, and 
NMI enable register 526. 

Transmit register 524 includes a transmit bit which 
is connected to transmit pin 602 of the serial port. Spe- 
cifically, the transmit bit is writable by NEB microproc- 
essor 173 via bus 181 and address decode logic 523, 
and in accordance with a binary 1 or 0 state of that trans- 
mit bit a corresponding +5 or 0 volt voltage level appears 
at transmit terminal 602. 

Receive register 525 includes a receive bit which is 
connected to receive pin 601 of the software serial port. 
More specifically, in accordance with a voltage level 
which appears at receive terminal 601 , the receive bit is 
set to a binary 0 or 1 , and the receive bit may be read 
by microprocessor 1 73 via bus 1 81 and address decode 
logic 523. 

NMI enable register 526 is a switch controllable by 
microprocessor 173 and which is connected between 
receive terminal 601 and NMI pin 1731. Under control 
of microprocessor 1 73 and via bus 1 81 and address de- 
code logic 523, NMI enable register 526 is switchable 
between an enable state in which signals appearing at 
receive terminal 601 are connected to NMI pin 1731, 
and a disable state in which signals appearing at receive 
terminal 601 are blocked. 

Transmit register 524, receive register 525, and 
NMI register 526 can physically be constructed from a 
single register, but more typically each are provided in 
a separately addressable register, as shown in Figure 
22. 

Figure 23(a) shows serial port processing in a serial 
receive mode. The process steps illustrated in Figure 
23(a) are executed by NEB microprocessor 173 in ac- 
cordance with software instructions stored in DRAM 
175. 

In step S2301, microprocessor 173 enables NMI 
enable register 526 so as to permit transmission of sig- 
nals appearing at receive terminal 601 directly to NMI 
pin 1 731 . Then in step S2302, microprocessor 1 73 mon- 
itors its NMI pin 1731 for the appearance of an NMI sig- 
nal. If no non-maskable interrupt has been received, mi- 
croprocessor 173 continues with ongoing processing 
(step S2303), such as continuing with networked print- 
ing operations between the computerized LAN 1 00 and 
the printer. 

On the other hand, when an NMI signal is received 
at NMI pin 1731 , flow advances to step S2304 in which 
microprocessor 173 interrupts on-going processes. As 
seen in Figure 23(b), because NMI enable register has 
been enabled, an NMI signal will be received in corre- 
spondence to a start bit at receive terminal 601. Figure 
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23(b) illustrates timing of signals in a serial receive 
mode. Thus, as seen in Figure 23(b), when a voltage 
level 610 corresponding to a start bit appears at receive 
terminal 601 , because ot the enable state of NMI enable 
register 526, that start bit is transmitted to NMI pin 1731 . 5 
At the same time, because of voltage level 610 associ- 
ated with the start bit, the receive bit in receive register 
525 switches to a binary 1 . 

Reverting to Figure 23(a), after microprocessor 173 
interrupts on-going processes (step S2304), the micro- 
processor begins execution of an NMI interrupt handling 
procedure which; in step S2305, disables NMI enable 
register 526 so as to block transmission of other signals 
from receive terminal 601 to NMI pin 1 731 . The interrupt 
handling procedure then waits for a serial transmission 
period so as to allow the first data bit to appear at receive 
terminal 601. In situations where serial transmission is 
conducted at 19.2 KHz, the predetermined serial trans- 
mission period is 1/19.2 KHz or 52 u.s. After the prede- 
termined serial transmission period is over, flow advanc- 
es to step S2307 in which the received bit in receive reg- 
ister 525 is read. This is shown in Figure 23(b) in which, 
for illustrative purposes, the first data bit is a binary 1 
corresponding to a high voltage level at receive terminal 
601 . The received bit is retrieved from receive register 
525 and steps S2306 and S2307 are repeated (step 
S2308) until eight data bits have been received. Any 
stop bits (such as 61 1 in Figure 23(b)) that are transmit- 
ted are simply ignored. 

When eight data bits have been received, flow then 
advances to step S2309 in which the interrupt handling 
procedure stores an 8-bit byte of data which has been 
received at the receive terminal 601 . In step S2310, mi- 
croprocessor 173 enables the NMI enable register 526 
so as to be prepared for receipt of a next serial trans- 
mission. The serial communication cycle for receiving 
one byte of serial data is then complete. 

In step S2311, microprocessor 173 determines 
whether the 8-bit byte stored in step S2309 requests an 
asynchronous break-in to ongoing software tasks. More 
specifically, once the NMI interrupt handling procedure 
described above has terminated, flow ordinarily returns 
to ongoing processes such as CPSOCKET and the like, 
all under control of the MONITOR. One benefit of an 
NMI -driven serial port, however, is the ability to break 
into a running program in the midst of a problem. For 
example, in situations where the NEB has crashed due 
to unexpected software problems, the state of the NEB 
is often unknown. It might be in a very tight microproc- 
essor loop that has no debug messages being transmit- 
ted. Resetting the NEB, which is often the only way to 
break the microprocessor loop, will lose the current state 
and will provide no information as to the cause of the 
crash. In such a situation, the ability to break in via the 
NMI -driven serial port and examine the system is ex- 
tremely valuable. 

Accordingly, step S2311 determines whether the 
byte received on the serial port connector requests 



asynchronous break-in. For example, by previously-ar- 
ranged convention, it might be determined that trans- 
mission of an exclamation point ("!") signifies a request 
for asynchronous break-in. In those instances, micro- 
processor 173 continues to suspend ongoing process- 
es, and enters an interactive debugger. The interactive 
debugger is a ROM-resident program that allows a user 
to view or to change memory addresses, CPU registers 
and I/O ports. Additionally, the interactive debugger al- 
lows two set break points in the code and has the ability 
to start execution from any such break point. This is all 
accomplished across serial port connector 600. 

Thus, asynchronous break-in permits a trouble- 
shooter to analyze the current state of NEB when a prob- 
lem has been encountered. Since the start bit on a serial 
communication causes an NMI signal to be generated, 
asynchronous break-in allows to begin an interactive 
debug session in which even a tightly-bound microproc- 
essor loop may be interrupted so as to permit analysis 
of the system stale. 

On the other hand, if the 8-bit byte stored in step 
S2309 does not request asynchronous break-in, then 
microprocessor 1 73 simply stores the received byte and 
returns to step S2303 in which it resumes execution" of 
ongoing processes that had been suspended in step 
S2304. Typically, other software modules active on mi- 
croprocessor 173, such as CPSOCKET, monitor the 
data buffer into which the 8-bit byte has been stored. 
For example, by a previously-arranged convention, it 
might be determined that transmission of the character 
sequence "DNLD" signifies a request for down load serv- 
ices in which a new software module or modules are 
downloaded over the serial port connector 600. In such 
an instance, CPSOCKET might be arranged so as to 
echo each of the "DNLD" characters as they are re- 
ceived and thereafter to enter a download mode. 

Figure 24(a) shows flow processing in the transmit 
mode of the software serial port, and Figure 24(b) shows 
signals appearing at transmit terminal 602 in connection 
with transmit bits written into transmit register 524. 

in step S2401, microprocessor 173 writes a binary 
1 start bit to the transmit bit in transmit register 524. The 
transmit bit, since it is connected to transmit terminal 
602, causes a +5 voltage level to appear at transmit ter- 
minal 602. 

Flow then advances to step S2402 in which NEB 
microprocessor 173 waits a predetermined serial trans- 
mission period which, at a serial rate of 1 9.2 KHz corre- 
sponds to 1/1 9.2 = 52 U.S (one inter-bit time). After wait- 
ing the required period, microprocessor 173 writes the 
first bit in the transmitted word to the transmit bit in trans- 
mit register 524 (step S2403). Until all eight bits of the 
transmitted word have been written (step S2404), mi- 
croprocessor 173 repeats steps S2402 and S2403 in 
which it waits for the serial transmission period and 
writes a next data bit to the transmit bit in transmit reg- 
ister 524. After all eight bits have been written, flow ad- 
vances to step S2405 which, after waiting for the inter- 
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bit transmission period, writes a stop bit to register 524, 
and then to step S2406 at which point serial transmis- 
sion is complete. 

The invention has been described with respect to a 
particular illustrative embodiment. It is to be understood 
that the invention is not limited to the above described 
embodiment and that various changes and modifica- 
tions may be made by those of ordinary skill in the art 
without departing from the spirit and scope of the inven- 
tion. 



Claims 

1. A reprogrammable network communication device 
which communicates on a network, comprising: 

a reprogrammable read only memory which 
stores a current program image, a current net- 
work information file block containing configu- 
ration information for the network communica- 
tion device, and a software module for repro- 
gramming said reprogrammable read only 
memory; 

a random access memory which stores a new 
program image for said reprogrammable read 
only memory; 

a processor which sends and receives network 
communications, which confirms that the new 
program image is compatible with the configu- 
ration information in the current network infor- 
mation file block, and which executes the soft- 
ware reprog ramming module so as to repro- 
gram the reprogrammable read only memory 
with the new program image in a case where 
compatibility is confirmed. 

2. A reprogrammable network communication device 
according to Claim 1, wherein the new program 
image includes a new network information file 
block, and wherein said processor replaces at least 
a part of the new network information file block with 
corresponding parts of the current network informa- 
tion file block before executing the software repro- 
gramming module. 

3. A reprogrammable network communication device 
according to Claim 2, wherein the new program 
image is downloaded to the network communication 
device over the network. 

4. A reprogrammable network communication device 
according to Claim 3, wherein the configuration 
information in the current network informatipn file 
block includes a MAC address. 

5. A reprogrammable network communication device 
according to Claim 4, wherein the configuration 



_ information in the current network information file 
block includes network media configuration infor- 
mation, and wherein said processor confirms com- 
patibility of the new program image by comparing 
5 the network media configuration information in the 
current network information file block with network 
media configuration information in the new network 
information file block. 

10 6. A reprogrammable network communication device 
according to Claim 4, wherein the configuration 
information in the current network information file 
block includes host interface configuration informa- 
tion, and wherein said processor confirms compat- 

15 ibility of the new program image by comparing the 
host interface configuration information in the cur- 
rent network information file block with host inter- 
face configuration information in the new network 
information file block. 

20 

7. A reprogrammable network communication device 
according to Claim 4, wherein the configuration 
information in the current network information file 
block includes product configuration information, 

2B and wherein said processor confirms compatibility 
of the new program image by comparing the product 
configuration information in the current network 
information file block with product configuration 
information in the new network information file 

30 block. 

8. A reprogrammable network communication device 
according to Claim 4, wherein the configuration 
information in the current network information file 

35 block includes processor configuration information, 
and wherein said processor confirms compatibility 
of the new program image by comparing the proc- 
essor configuration information in the current net- 
work information file block with processor configu- 
re ration information in the new network information 
file block. 

9. A reprogrammable network communication device 
according to Claim 4, wherein the configuration 

45 information in the current network information file 
block includes memory configuration information, 
and wherein said processor confirms compatibility 
of the new program image by comparing the mem- 
ory configuration information in the current network 

so information file block with memory configuration 

information in the new network information file 
block. 

10. A method for reprogramming a network communi- 
sm cation device which communicates on a network, 

comprising the steps of: 

storing in a reprogrammable read only memory 
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device a current program image, a current net- 
work information file block containing configu- 
ration information for the network communica- 
tion device, and a software rep rog ramming 
module for reprogramming the reprogramma- £ 
ble read only memory; 

storing in a random access memory a new pro- 
gram image for the reprogrammable read only 
memory; 

confirming that the new program image is com- 
patible with the configuration information in the 
current network information file block; 
executing the software reprogramming module 
so as to reprogram the reprogrammable read 
only memory with the new program image in a 
case where compatibility is confirmed. 

11. A method according to Claim 10, wherein the new 
program image includes a new network information 
file block, and further comprising the step of replac- 
ing at least a part of the new network information 
file block with corresponding parts of the current 
network information file block before execution of 
the software reprogramming module. 

1 2. A method according to Claim 1 1 , further comprising 
the step of downloading the new program image to 
the network communication device over the net- 
work. 

13. A method according to Claim 12, wherein the con- 
figuration information in the current network infor- 
mation file block includes a MAC address. 

14. A method according to Claim 13, wherein the con- 
figuration information in the current network infor- 
mation file block includes network media configura- 
tion information, and wherein compatibility of the 
new program image is confirmed by comparing the 
network media configuration information in the cur- 
rent network information file block with network 
media configuration information in the new network 
information file block. 

15. A method according to Claim 13, wherein the con- 
figuration information in the current network infor- 
mation file block includes host interface configura- 
tion information, and wherein compatibility of the 
new program image is confirmed by comparing the 
host interface configuration information in the cur- 
rent network information file block with host inter- 
face configuration information in the new network 
information file block. 

16. A method according to Claim 1 3, wherein the con- 
figuration information in the current network infor- 
mation file block includes product configuration 
information, and wherein compatibility of the new 



-program image is confirmed by comparing the prod- 
uct configuration information in the current network 
information file block with product configuration 
information in the new network information file 
block. 

17. A method according to Claim 1 3, wherein the con- 
figuration information in the current network infor- 
mation file block includes processor configuration 
information, and wherein compatibility of the new 
program image is confirmed by comparing the proc- 
essor configuration information in the current net- 
work information file block with processor configu- 
ration information in the new network information 
file block. 

18. A method according to Claim 1 3, wherein the con- 
figuration information in the current network infor- 
mation file block includes memory configuration 
information, and wherein compatibility of the new 
program image is confirmed by comparing the 
memory configuration information in the current 
network information file block with memory config- 
uration information in the new network information 
file block. 

1 9. A device or method having the features of any com- 
bination of the preceding claims. 
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